博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Qt之QTableView显示富文本
阅读量:5743 次
发布时间:2019-06-18

本文共 1696 字,大约阅读时间需要 5 分钟。

简述

对于QTableView中的显示,我们前面介绍过很多种,其中包括:文本、进度条、复选框等,今天我们介绍一下关于富文本的显示。

可能绝大多数小伙伴会通过QAbstractTableModel中的data来实现,可是现实告诉我们,那是行不通的,那么我们如何去显示呢?请看正文。

效果

这里写图片描述

源码

下面我们使用QAbstractItemDelegate来进行富文本的显示,主要通过QTextDocument设置HTML代码来实现。

void CheckBoxDelegate::paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const{    QStyleOptionViewItem viewOption(option);    initStyleOption(&viewOption, index);    if (option.state.testFlag(QStyle::State_HasFocus))        viewOption.state = viewOption.state ^ QStyle::State_HasFocus;    // ... 省略    // 设置显示文本为空,使用默认样式    QStyle *pStyle = viewOption.widget? viewOption.widget->style() : QApplication::style();    viewOption.text = "";    pStyle->drawControl(QStyle::CE_ItemViewItem, &viewOption, painter, viewOption.widget);    // 需要显示的HTML    QString strHTML = QString(" \                               \                               \                               \                              \                              %1%2 \                               \                               \                              ").arg("I am a ").arg("Qter");    QTextDocument doc;    doc.setHtml(strHTML);    QAbstractTextDocumentLayout::PaintContext paintContext;    QRect textRect = pStyle->subElementRect(QStyle::SE_ItemViewItemText, &viewOption);    painter->save();    // 坐标变换,将左上角设置为原点    painter->translate(textRect.topLeft());    // 设置HTML绘制区域    painter->setClipRect(textRect.translated(-textRect.topLeft()));    doc.documentLayout()->draw(painter, paintContext);    painter->restore();}

分析

首先我们需要保留原有样式,所以设置QStyleOptionViewItem的文本为空,然后调用QStyle的drawControl接口来进行绘制,然后通过QTextDocument设置HTML代码,利用QPainter来进行文本的绘制,绘制区域通过整个文本区域经过坐标变换后得到的。

你可能感兴趣的文章
如何学习区块链
查看>>
搜索问题的办法
查看>>
微信分销系统商城营销5大重点
查看>>
求职准备 - 收藏集 - 掘金
查看>>
htm5新特性(转)
查看>>
Linux-Centos启动流程
查看>>
php 设计模式
查看>>
后端技术精选 - 收藏集 - 掘金
查看>>
Laravel 服务容器
查看>>
mac安装kubernetes并运行echoserver
查看>>
多页架构的前后端分离方案(webpack+express)
查看>>
算法(第4版) Chapter 1
查看>>
前端技术选型的遗憾和经验教训
查看>>
“亲切照料”下的领域驱动设计
查看>>
SRE工程师到底是做什么的?
查看>>
解读:Red Hat为什么收购Ansible
查看>>
Ossim下的安全合规管理
查看>>
DelphiWebMVC框架下BPL热部署实现
查看>>
C++与MySQL的冲突
查看>>
siki学习之观察者模式笔记
查看>>